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1. Errata Table 
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2. Errata Descriptions and Workarounds 


Erratum #1: 


Erratum #2: 


When the outgoing transaction buffer is full, a pending outgoing 
interrupt request causes data contention with a foreign system bus 
write of IO for store (WIO). 


Applicability: 
UltraSPARC IV versions 2.3, 2.4, 3.1, and 3.2. 


Description: 


When the outgoing transaction buffer in the Transaction Out Buffer (TOB) is 
full, it cannot accept an outgoing interrupt. If the Coherent Pending Queue 
(CPQ) is processing a foreign system bus write of IO for store (WIO) write to 
one of the Memory Controller Unit (MCU) control registers at the same time, a 
data contention occurs in the mux that selects the Address Space Identifier 
(ASI) write data and the foreign WIO data. 

Impact: 

This data contention causes incorrect data to be written into the MCU control 
registers. 

Workaround: 

Issue a foreign WIO request only when the processor is in a quiescent state 
without any outstanding outgoing requests. 

Status: 


This bug will not be fixed in future releases of the silicon. 
Two CPUs without explicit synchronization doing instruction 
modification may cause both CPUs to hang and corrupt data. 


Applicability: 
UltraSPARC IV versions 2.3, 2.4, 3.1, and 3.2. 


UltraSPARC-IV Errata - 12/12/07 
Part No. 820-4010-10 








Erratum #3: 


Description: 


CPU (CPU "A") executes a load instruction that cannot be serviced by the on- 
chip data cache while another CPU (CPU "B") modifies CPU A’s load 
instruction during a window of time that spans the initial fetching of the load 
instruction and a subsequent refetching of that same load instruction. 

Impact: 


The two CPUs may deadlock and depending on how CPU B modifies CPU A’s 
load instruction, data corruption may also occur (this situation will not occur in 
the case of a single CPU that is executing self-modifying code). 

Workaround: 


Do not modify code running on another CPU without explicit synchronization. If 
an instruction must be modified without synchronization, avoid using all types 
of load instructions. 

Status: 


This bug will not be fixed in future releases of the silicon. 


Privileged mode store alternate using Address Space Identifier 
(ASI) 0x64 hangs the machine. 


Applicability: 
UltraSPARC IV versions 2.3, 2.4, 3.1, and 3.2. 


Description: 


In privileged mode, a store alternate operation using Address Space Identifier 
(ASI) 0x64 should be flagged as using an illegal ASI and should result in a 
data_access_exception trap. But this checking is not present, so the store is 
allowed to execute and is never acknowledged. 


Impact: 


The machine hangs in privileged mode (behavior in user mode is correct, so a 
malevolent user cannot hang the machine). 
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Erratum #4: 


Erratum #5: 


Workaround: 


The privileged code should not issue store alternates to ASI 0x64. 


Status: 


This bug will not be fixed in future releases of the silicon. 


The Floating Point Disabled (FP_Disabled) Trap is taken with the 
PDIST instruction when DCR.IFPOE is disabled. 


Applicability: 
UltraSPARC IV versions 2.3, 2.4, 3.1, and 3.2. 


Description: 


The processor sometimes takes an Floating Point Disabled (FP_Disabled) trap 
when the floating-point unit is enabled (PSTATE.PEF == 1 and FPRS.FEF == 
1) and the Interrupt Floating-Point Operation Enable mode bit is disabled 
(DCR.IFPOE == 0). 

Impact: 


The processor may generate an FP_Disabled trap when IFPOE = 0. This bug 
only affects Pixel Component Distance (PDIST) instructions that trigger 
recirculations. 

Workaround: 


There is no workaround to bypass this problem. 


Status: 


This bug will not be fixed in future releases of the silicon. 
The protocol error on the system bus (PERR) is reported from 
programs that have heavy write transactions. 


Applicability: 
UltraSPARC IV versions 2.3, 2.4, and 3.1. 
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Erratum #6: 


Description: 


The effect of a canceled writeback (WB) stops the memory write transaction of 
a prior write request to the same memory bank. This causes the Targld that’s 
being used by the prior write to be unable to retire and all the subsequent 
requests to the same memory bank cannot be dequeued from the memory 
request queue. 


e The two write transactions that affect each other need to come from the same CPU 
with the same transaction ID and also target to the same CPU memory ban. 


e The write transaction to the target CPU needs to be heavy enough to use up all 
regular Targld. 
Impact: 


Many types of PERR (i.e., a protocol error has occurred on the system bus) 
timeout errors (e.g., Coherent Pending Queue [CPQ_TO], Targld [TID_TO], 
and Write Queue [WQ_TO]) falsely assert the ERROR pin. 

Workaround: 


There is no workaround to bypass this problem. 


Status: 


This bug will not be fixed in future releases of the silicon. 


The internal processor error (IERR) is reported from programs with 
heavy write transactions targeting one CPU. 


Applicability: 
UltraSPARC IV version 2.3. 


Description: 


Once the Memory Controller Unit (MCU) receives the write data ready for a 
zero targld case, it can start another write data check for the next entry that 
might again use a zero targld. When there are heavy write transactions 
targeting one CPU, however, the control logic does not process all of the 
control signals in time. When this happens, a spurious wrt_data_ready will be 
sent to the MCU bank, which causes the MCU to send a wrt_data_request 
prematurely. 
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Erratum #7: 


Impact: 

Many types of internal processor errors (IERRs) (e.g., unexpected write data 
request [WRD_UE], Undefined DTransID [UDT], or overwrite a valid S2M RAM 
entry [S2M_WER]) falsely assert the ERROR pin. 

Workaround: 


There is no workaround to bypass this problem. 


Status: 


This bug will not be fixed in future releases of the silicon. 


An incorrect context number is placed in the Data Memory 
Management Unit (DMMU) Tag Access register after a 
data_access_exception trap. 


Applicability: 
UltraSPARC IV versions 2.3, 2.4, 3.1, and 3.2. 


Description: 


When a floating point load on the AX pipe takes a data_access exception trap, 
the wrong context number may be saved in the context field of the Data 
Memory Management Unit (DMMU) Tag Access register (ASI 0x58, VA=0x30). 


Impact: 
The incorrect context number is provided to the data_access_exception trap 
handler. 


Workaround: 


Use the CT field (context ID) of the DMMU Synchronous Fault Status register 
(SFSR, ASI 0x58, VA=0x18). The data_access_exception trap handler should 
refer to either the primary, secondary, or nucleus context registers to convert 
the 2-bit context ID into a 13-bit context number. See the bug tool for a code 
snippet. 


Status: 


This bug will not be fixed in future releases of the silicon. 
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